[INFO] cloning repository https://github.com/iolsen/sfb
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/iolsen/sfb" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fiolsen%2Fsfb", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fiolsen%2Fsfb'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] e1b3df9ee9907fd819df9f8400113fc25b475a5c
[INFO] checking iolsen/sfb against try#163937523761cc0def32f1ba9ed63fdf65ad3478 for pr-156749
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fiolsen%2Fsfb" "/workspace/builds/worker-1-tc2/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-1-tc2/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/iolsen/sfb
[INFO] finished tweaking git repo https://github.com/iolsen/sfb
[INFO] tweaked toml for git repo https://github.com/iolsen/sfb written to /workspace/builds/worker-1-tc2/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/iolsen/sfb on toolchain 163937523761cc0def32f1ba9ed63fdf65ad3478
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+163937523761cc0def32f1ba9ed63fdf65ad3478" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/iolsen/sfb already has a lockfile, it will not be regenerated
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+163937523761cc0def32f1ba9ed63fdf65ad3478" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-m" "1610612736" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:3e793bdf10248eb2ddbd6b0faebed8155c11b4589982e2893733958d93e8d540" "sleep" "infinity", kill_on_drop: false }`
[INFO] [stdout] 078ed15afe909ef270b5ed01a62216470a214a4ae502e1cc430c8fd680121f33
[INFO] running `Command { std: "docker" "start" "078ed15afe909ef270b5ed01a62216470a214a4ae502e1cc430c8fd680121f33", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "exec" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-w" "/opt/rustwide/workdir" "--user" "0:0" "078ed15afe909ef270b5ed01a62216470a214a4ae502e1cc430c8fd680121f33" "/opt/rustwide/cargo-home/bin/cargo" "+163937523761cc0def32f1ba9ed63fdf65ad3478" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "078ed15afe909ef270b5ed01a62216470a214a4ae502e1cc430c8fd680121f33", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "exec" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-w" "/opt/rustwide/workdir" "--user" "0:0" "078ed15afe909ef270b5ed01a62216470a214a4ae502e1cc430c8fd680121f33" "/opt/rustwide/cargo-home/bin/cargo" "+163937523761cc0def32f1ba9ed63fdf65ad3478" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stderr]    Compiling libc v0.2.70
[INFO] [stderr]    Compiling autocfg v1.0.0
[INFO] [stderr]    Compiling libm v0.2.1
[INFO] [stderr]    Compiling cc v1.0.53
[INFO] [stderr]    Compiling log v0.4.8
[INFO] [stderr]    Compiling proc-macro2 v1.0.13
[INFO] [stderr]    Compiling xml-rs v0.8.3
[INFO] [stderr]    Compiling syn v1.0.22
[INFO] [stderr]    Compiling cfg-if v0.1.10
[INFO] [stderr]    Compiling byteorder v1.3.4
[INFO] [stderr]    Compiling serde v1.0.110
[INFO] [stderr]    Compiling khronos_api v3.1.0
[INFO] [stderr]    Compiling syn v0.15.44
[INFO] [stderr]     Checking void v1.0.2
[INFO] [stderr]     Checking linked-hash-map v0.5.3
[INFO] [stderr]    Compiling nix v0.14.1
[INFO] [stderr]    Compiling getrandom v0.1.14
[INFO] [stderr]     Checking smallvec v0.6.13
[INFO] [stderr]     Checking lock_api v0.3.4
[INFO] [stderr]    Compiling ryu v1.0.4
[INFO] [stderr]    Compiling gimli v0.21.0
[INFO] [stderr]    Compiling arrayvec v0.4.12
[INFO] [stderr]    Compiling error-chain v0.12.2
[INFO] [stderr]    Compiling num-traits v0.2.11
[INFO] [stderr]    Compiling crossbeam-utils v0.7.2
[INFO] [stderr]    Compiling memoffset v0.5.4
[INFO] [stderr]    Compiling crossbeam-epoch v0.8.2
[INFO] [stderr]     Checking stb_truetype v0.3.1
[INFO] [stderr]    Compiling num-integer v0.1.42
[INFO] [stderr]     Checking draw_state v0.8.0
[INFO] [stderr]    Compiling x11-dl v2.18.5
[INFO] [stderr]     Checking downcast-rs v1.1.1
[INFO] [stderr]    Compiling rustc-demangle v0.1.16
[INFO] [stderr]    Compiling object v0.19.0
[INFO] [stderr]     Checking walkdir v2.3.1
[INFO] [stderr]     Checking gfx_core v0.9.2
[INFO] [stderr]    Compiling num-complex v0.2.4
[INFO] [stderr]    Compiling num-rational v0.2.4
[INFO] [stderr]     Checking ppv-lite86 v0.2.8
[INFO] [stderr]    Compiling pulldown-cmark v0.2.0
[INFO] [stderr]    Compiling typenum v1.12.0
[INFO] [stderr]    Compiling wayland-scanner v0.21.13
[INFO] [stderr]    Compiling quote v1.0.5
[INFO] [stderr]    Compiling gl_generator v0.13.1
[INFO] [stderr]    Compiling libloading v0.5.2
[INFO] [stderr]    Compiling gl_generator v0.14.0
[INFO] [stderr]     Checking crossbeam-deque v0.7.3
[INFO] [stderr]     Checking xdg v2.2.0
[INFO] [stderr]     Checking num_cpus v1.13.0
[INFO] [stderr]    Compiling itoa v0.4.5
[INFO] [stderr]    Compiling rand v0.4.6
[INFO] [stderr]     Checking rand_core v0.5.1
[INFO] [stderr]     Checking dlib v0.4.1
[INFO] [stderr]     Checking memmap v0.7.0
[INFO] [stderr]     Checking wayland-sys v0.21.13
[INFO] [stderr]     Checking rand_chacha v0.2.2
[INFO] [stderr]     Checking approx v0.3.2
[INFO] [stderr]     Checking ordered-float v1.0.2
[INFO] [stderr]     Checking line_drawing v0.7.0
[INFO] [stderr]    Compiling glutin_egl_sys v0.1.4
[INFO] [stderr]    Compiling glutin_glx_sys v0.1.6
[INFO] [stderr]     Checking rusttype v0.8.3
[INFO] [stderr]     Checking num-traits v0.1.43
[INFO] [stderr]    Compiling bzip2-sys v0.1.8+1.0.8
[INFO] [stderr]    Compiling gfx_gl v0.6.1
[INFO] [stderr]    Compiling minimp3-sys v0.3.2
[INFO] [stderr]    Compiling rand v0.6.5
[INFO] [stderr]    Compiling libudev-sys v0.1.4
[INFO] [stderr]    Compiling alsa-sys v0.1.2
[INFO] [stderr]     Checking rusttype v0.7.9
[INFO] [stderr]    Compiling bitflags v1.2.1
[INFO] [stderr]    Compiling same-file v1.0.6
[INFO] [stderr]     Checking andrew v0.2.1
[INFO] [stderr]    Compiling remove_dir_all v0.5.2
[INFO] [stderr]    Compiling nix v0.15.0
[INFO] [stderr]    Compiling tempdir v0.3.7
[INFO] [stderr]     Checking sid v0.5.2
[INFO] [stderr]     Checking rand v0.7.3
[INFO] [stderr]     Checking raw-window-handle v0.3.3
[INFO] [stderr]     Checking shared_library v0.1.9
[INFO] [stderr]     Checking rand_os v0.1.3
[INFO] [stderr]    Compiling imgui-sys v0.3.0
[INFO] [stderr]    Compiling num-iter v0.1.40
[INFO] [stderr]    Compiling glob v0.2.11
[INFO] [stderr]    Compiling addr2line v0.12.0
[INFO] [stderr]    Compiling wayland-client v0.21.13
[INFO] [stderr]    Compiling wayland-protocols v0.21.13
[INFO] [stderr]     Checking xi-unicode v0.2.0
[INFO] [stderr]     Checking smallvec v1.4.0
[INFO] [stderr]    Compiling backtrace v0.3.48
[INFO] [stderr]    Compiling bytecount v0.4.0
[INFO] [stderr]     Checking glyph_brush_layout v0.1.9
[INFO] [stderr]     Checking generic-array v0.12.3
[INFO] [stderr]     Checking parking_lot_core v0.7.2
[INFO] [stderr]     Checking alga v0.9.3
[INFO] [stderr]     Checking osmesa-sys v0.1.2
[INFO] [stderr]     Checking deflate v0.7.20
[INFO] [stderr]     Checking gfx v0.18.2
[INFO] [stderr]     Checking slice-deque v0.3.0
[INFO] [stderr]     Checking ogg v0.7.0
[INFO] [stderr]     Checking uuid v0.8.1
[INFO] [stderr]     Checking twox-hash v1.5.0
[INFO] [stderr]     Checking mint v0.5.5
[INFO] [stderr]     Checking lewton v0.9.4
[INFO] [stderr]     Checking glyph_brush v0.6.3
[INFO] [stderr]     Checking png v0.15.3
[INFO] [stderr]     Checking cpal v0.8.2
[INFO] [stderr]     Checking minimp3 v0.3.5
[INFO] [stderr]     Checking parking_lot v0.10.2
[INFO] [stderr]     Checking bzip2 v0.3.3
[INFO] [stderr]     Checking dirs-sys v0.3.4
[INFO] [stderr]     Checking jpeg-decoder v0.1.19
[INFO] [stderr]     Checking hound v3.4.0
[INFO] [stderr]     Checking nalgebra v0.18.1
[INFO] [stderr]     Checking podio v0.1.6
[INFO] [stderr]     Checking claxon v0.4.2
[INFO] [stderr]    Compiling imgui-gfx-renderer v0.3.0
[INFO] [stderr]     Checking zip v0.5.5
[INFO] [stderr]     Checking wayland-commons v0.21.13
[INFO] [stderr]     Checking glyph_brush v0.5.4
[INFO] [stderr]     Checking gfx_device_gl v0.16.2
[INFO] [stderr]     Checking directories v2.0.2
[INFO] [stderr]    Compiling euclid_macros v0.1.0
[INFO] [stderr]    Compiling num-derive v0.2.5
[INFO] [stderr]    Compiling smart-default v0.5.2
[INFO] [stderr]    Compiling serde_derive v1.0.110
[INFO] [stderr]     Checking euclid v0.19.9
[INFO] [stderr]     Checking lyon_geom v0.12.7
[INFO] [stderr]     Checking tiff v0.3.1
[INFO] [stderr]     Checking lyon_path v0.13.2
[INFO] [stderr]     Checking gilrs-core v0.2.6
[INFO] [stderr]     Checking image v0.22.5
[INFO] [stderr]     Checking lyon_algorithms v0.13.4
[INFO] [stderr]     Checking lyon_tessellation v0.13.5
[INFO] [stderr]     Checking gilrs v0.7.4
[INFO] [stderr]     Checking lyon v0.13.5
[INFO] [stderr]     Checking imgui v0.3.0
[INFO] [stderr]     Checking rodio v0.9.0
[INFO] [stderr]     Checking toml v0.5.6
[INFO] [stderr]    Compiling semver v0.9.0
[INFO] [stderr]    Compiling serde_json v1.0.53
[INFO] [stderr]    Compiling rustc_version v0.2.3
[INFO] [stderr]    Compiling parking_lot_core v0.6.2
[INFO] [stderr]    Compiling parking_lot v0.9.0
[INFO] [stderr]    Compiling cargo_metadata v0.6.4
[INFO] [stderr]    Compiling skeptic v0.13.4
[INFO] [stderr]    Compiling ggez v0.5.1
[INFO] [stderr]     Checking smithay-client-toolkit v0.4.6
[INFO] [stderr]     Checking winit v0.19.5
[INFO] [stderr]     Checking glutin v0.20.1
[INFO] [stderr]     Checking gfx_window_glutin v0.30.0
[INFO] [stderr]     Checking sfb v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: enum `BearingTo` is never used
[INFO] [stdout]   --> src/hex.rs:68:10
[INFO] [stdout]    |
[INFO] [stdout] 68 | pub enum BearingTo {
[INFO] [stdout]    |          ^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Cube` is never constructed
[INFO] [stdout]    --> src/hex.rs:108:8
[INFO] [stdout]     |
[INFO] [stdout] 108 | struct Cube {
[INFO] [stdout]     |        ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]    --> src/hex.rs:132:12
[INFO] [stdout]     |
[INFO] [stdout] 120 | impl Hex {
[INFO] [stdout]     | -------- associated items in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 132 |     pub fn from_label(label: &str) -> Option<Hex> {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 155 |     pub fn distance_to(&self, other: &Hex) -> i8 {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 159 |     pub fn bearing_to(&self, other: &Hex) -> BearingTo {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 186 |     fn angle_to(&self, other: &Hex) -> i16 {
[INFO] [stdout]     |        ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 215 |     fn center_coords(&self) -> Point2<f32> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 247 |     fn to_cube(&self) -> Cube {
[INFO] [stdout]     |        ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 254 |     fn cubic_distance(a: Cube, b: Cube) -> i8 {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `height` is never read
[INFO] [stdout]  --> src/screen/map.rs:8:9
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub struct MapState {
[INFO] [stdout]   |            -------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 8 |     pub height: f32,
[INFO] [stdout]   |         ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `speed` and `spec` are never read
[INFO] [stdout]   --> src/ship.rs:29:9
[INFO] [stdout]    |
[INFO] [stdout] 25 | pub struct Ship {
[INFO] [stdout]    |            ---- fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 29 |     pub speed: u8,
[INFO] [stdout]    |         ^^^^^
[INFO] [stdout] 30 |
[INFO] [stdout] 31 |     spec: ShipSpec,
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `set_energy_allocation` and `rotate_to` are never used
[INFO] [stdout]    --> src/ship.rs:97:12
[INFO] [stdout]     |
[INFO] [stdout]  39 | impl Ship {
[INFO] [stdout]     | --------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout]  97 |     pub fn set_energy_allocation(&mut self, e: EnergyAllocation) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 102 |     pub fn rotate_to(&mut self, new_facing: Facing) {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `defenses`, `power`, and `ship` are never read
[INFO] [stdout]   --> src/ship_spec.rs:11:9
[INFO] [stdout]    |
[INFO] [stdout]  9 | pub struct ShipSpec {
[INFO] [stdout]    |            -------- fields in this struct
[INFO] [stdout] 10 |     pub fx: Fx,
[INFO] [stdout] 11 |     pub defenses: Defenses,
[INFO] [stdout]    |         ^^^^^^^^
[INFO] [stdout] 12 |     pub power: Power,
[INFO] [stdout]    |         ^^^^^
[INFO] [stdout] 13 |     pub ship: Ship,
[INFO] [stdout]    |         ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple fields are never read
[INFO] [stdout]   --> src/ship_spec.rs:23:9
[INFO] [stdout]    |
[INFO] [stdout] 22 | pub struct Defenses {
[INFO] [stdout]    |            -------- fields in this struct
[INFO] [stdout] 23 |     pub shield1: u8,
[INFO] [stdout]    |         ^^^^^^^
[INFO] [stdout] 24 |     pub shield2: u8,
[INFO] [stdout]    |         ^^^^^^^
[INFO] [stdout] 25 |     pub shield3: u8,
[INFO] [stdout]    |         ^^^^^^^
[INFO] [stdout] 26 |     pub shield4: u8,
[INFO] [stdout]    |         ^^^^^^^
[INFO] [stdout] 27 |     pub shield5: u8,
[INFO] [stdout]    |         ^^^^^^^
[INFO] [stdout] 28 |     pub shield6: u8,
[INFO] [stdout]    |         ^^^^^^^
[INFO] [stdout] 29 |     pub armor: u8,
[INFO] [stdout]    |         ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `left_warp`, `center_warp`, `right_warp`, `impulse`, and `battery` are never read
[INFO] [stdout]   --> src/ship_spec.rs:34:9
[INFO] [stdout]    |
[INFO] [stdout] 33 | pub struct Power {
[INFO] [stdout]    |            ----- fields in this struct
[INFO] [stdout] 34 |     pub left_warp: u8,
[INFO] [stdout]    |         ^^^^^^^^^
[INFO] [stdout] 35 |     pub center_warp: u8,
[INFO] [stdout]    |         ^^^^^^^^^^^
[INFO] [stdout] 36 |     pub right_warp: u8,
[INFO] [stdout]    |         ^^^^^^^^^^
[INFO] [stdout] 37 |     pub impulse: u8,
[INFO] [stdout]    |         ^^^^^^^
[INFO] [stdout] 38 |     pub battery: u8,
[INFO] [stdout]    |         ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `forward_hull` and `aft_hull` are never read
[INFO] [stdout]   --> src/ship_spec.rs:43:9
[INFO] [stdout]    |
[INFO] [stdout] 42 | pub struct Ship {
[INFO] [stdout]    |            ---- fields in this struct
[INFO] [stdout] 43 |     pub forward_hull: u8,
[INFO] [stdout]    |         ^^^^^^^^^^^^
[INFO] [stdout] 44 |     pub aft_hull: u8,
[INFO] [stdout]    |         ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]  --> src/screen/energy_allocation_window.rs:9:19
[INFO] [stdout]   |
[INFO] [stdout] 9 |     pub fn new(e: &EnergyAllocation) -> EnergyAllocationWindow {
[INFO] [stdout]   |                   ^^^^^^^^^^^^^^^^^     ^^^^^^^^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]   |                   |
[INFO] [stdout]   |                   the lifetime is elided here
[INFO] [stdout]   |
[INFO] [stdout]   = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout]   = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]   |
[INFO] [stdout] 9 |     pub fn new(e: &EnergyAllocation) -> EnergyAllocationWindow<'_> {
[INFO] [stdout]   |                                                               ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: non-local `impl` definition, `impl` blocks should be written at the same level as their item
[INFO] [stdout]  --> src/ship_spec.rs:8:10
[INFO] [stdout]   |
[INFO] [stdout] 8 | #[derive(Deserialize)]
[INFO] [stdout]   |          ^----------
[INFO] [stdout]   |          |
[INFO] [stdout]   |          `Deserialize` is not local
[INFO] [stdout]   |          move the `impl` block outside of this constant `_IMPL_DESERIALIZE_FOR_ShipSpec`
[INFO] [stdout] 9 | pub struct ShipSpec {
[INFO] [stdout]   |            -------- `ShipSpec` is not local
[INFO] [stdout]   |
[INFO] [stdout]   = note: the derive macro `Deserialize` defines the non-local `impl`, and may need to be changed
[INFO] [stdout]   = note: the derive macro `Deserialize` may come from an old version of the `serde_derive` crate, try updating your dependency with `cargo update -p serde_derive`
[INFO] [stdout]   = note: an `impl` is never scoped, even when it is nested inside an item, as it may impact type checking outside of that item, which can be the case if neither the trait or the self type are at the same nesting level as the `impl`
[INFO] [stdout]   = note: items in an anonymous const item (`const _: () = { ... }`) are treated as in the same scope as the anonymous const's declaration for the purpose of this lint
[INFO] [stdout]   = note: `#[warn(non_local_definitions)]` on by default
[INFO] [stdout]   = note: this warning originates in the derive macro `Deserialize` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: non-local `impl` definition, `impl` blocks should be written at the same level as their item
[INFO] [stdout]   --> src/ship_spec.rs:16:10
[INFO] [stdout]    |
[INFO] [stdout] 16 | #[derive(Deserialize)]
[INFO] [stdout]    |          ^----------
[INFO] [stdout]    |          |
[INFO] [stdout]    |          `Deserialize` is not local
[INFO] [stdout]    |          move the `impl` block outside of this constant `_IMPL_DESERIALIZE_FOR_Fx`
[INFO] [stdout] 17 | pub struct Fx {
[INFO] [stdout]    |            -- `Fx` is not local
[INFO] [stdout]    |
[INFO] [stdout]    = note: the derive macro `Deserialize` defines the non-local `impl`, and may need to be changed
[INFO] [stdout]    = note: the derive macro `Deserialize` may come from an old version of the `serde_derive` crate, try updating your dependency with `cargo update -p serde_derive`
[INFO] [stdout]    = note: an `impl` is never scoped, even when it is nested inside an item, as it may impact type checking outside of that item, which can be the case if neither the trait or the self type are at the same nesting level as the `impl`
[INFO] [stdout]    = note: items in an anonymous const item (`const _: () = { ... }`) are treated as in the same scope as the anonymous const's declaration for the purpose of this lint
[INFO] [stdout]    = note: this warning originates in the derive macro `Deserialize` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: non-local `impl` definition, `impl` blocks should be written at the same level as their item
[INFO] [stdout]   --> src/ship_spec.rs:21:10
[INFO] [stdout]    |
[INFO] [stdout] 21 | #[derive(Deserialize)]
[INFO] [stdout]    |          ^----------
[INFO] [stdout]    |          |
[INFO] [stdout]    |          `Deserialize` is not local
[INFO] [stdout]    |          move the `impl` block outside of this constant `_IMPL_DESERIALIZE_FOR_Defenses`
[INFO] [stdout] 22 | pub struct Defenses {
[INFO] [stdout]    |            -------- `Defenses` is not local
[INFO] [stdout]    |
[INFO] [stdout]    = note: the derive macro `Deserialize` defines the non-local `impl`, and may need to be changed
[INFO] [stdout]    = note: the derive macro `Deserialize` may come from an old version of the `serde_derive` crate, try updating your dependency with `cargo update -p serde_derive`
[INFO] [stdout]    = note: an `impl` is never scoped, even when it is nested inside an item, as it may impact type checking outside of that item, which can be the case if neither the trait or the self type are at the same nesting level as the `impl`
[INFO] [stdout]    = note: items in an anonymous const item (`const _: () = { ... }`) are treated as in the same scope as the anonymous const's declaration for the purpose of this lint
[INFO] [stdout]    = note: this warning originates in the derive macro `Deserialize` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: non-local `impl` definition, `impl` blocks should be written at the same level as their item
[INFO] [stdout]   --> src/ship_spec.rs:32:10
[INFO] [stdout]    |
[INFO] [stdout] 32 | #[derive(Deserialize)]
[INFO] [stdout]    |          ^----------
[INFO] [stdout]    |          |
[INFO] [stdout]    |          `Deserialize` is not local
[INFO] [stdout]    |          move the `impl` block outside of this constant `_IMPL_DESERIALIZE_FOR_Power`
[INFO] [stdout] 33 | pub struct Power {
[INFO] [stdout]    |            ----- `Power` is not local
[INFO] [stdout]    |
[INFO] [stdout]    = note: the derive macro `Deserialize` defines the non-local `impl`, and may need to be changed
[INFO] [stdout]    = note: the derive macro `Deserialize` may come from an old version of the `serde_derive` crate, try updating your dependency with `cargo update -p serde_derive`
[INFO] [stdout]    = note: an `impl` is never scoped, even when it is nested inside an item, as it may impact type checking outside of that item, which can be the case if neither the trait or the self type are at the same nesting level as the `impl`
[INFO] [stdout]    = note: items in an anonymous const item (`const _: () = { ... }`) are treated as in the same scope as the anonymous const's declaration for the purpose of this lint
[INFO] [stdout]    = note: this warning originates in the derive macro `Deserialize` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: non-local `impl` definition, `impl` blocks should be written at the same level as their item
[INFO] [stdout]   --> src/ship_spec.rs:41:10
[INFO] [stdout]    |
[INFO] [stdout] 41 | #[derive(Deserialize)]
[INFO] [stdout]    |          ^----------
[INFO] [stdout]    |          |
[INFO] [stdout]    |          `Deserialize` is not local
[INFO] [stdout]    |          move the `impl` block outside of this constant `_IMPL_DESERIALIZE_FOR_Ship`
[INFO] [stdout] 42 | pub struct Ship {
[INFO] [stdout]    |            ---- `Ship` is not local
[INFO] [stdout]    |
[INFO] [stdout]    = note: the derive macro `Deserialize` defines the non-local `impl`, and may need to be changed
[INFO] [stdout]    = note: the derive macro `Deserialize` may come from an old version of the `serde_derive` crate, try updating your dependency with `cargo update -p serde_derive`
[INFO] [stdout]    = note: an `impl` is never scoped, even when it is nested inside an item, as it may impact type checking outside of that item, which can be the case if neither the trait or the self type are at the same nesting level as the `impl`
[INFO] [stdout]    = note: items in an anonymous const item (`const _: () = { ... }`) are treated as in the same scope as the anonymous const's declaration for the purpose of this lint
[INFO] [stdout]    = note: this warning originates in the derive macro `Deserialize` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `height` is never read
[INFO] [stdout]  --> src/screen/map.rs:8:9
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub struct MapState {
[INFO] [stdout]   |            -------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 8 |     pub height: f32,
[INFO] [stdout]   |         ^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `speed` and `spec` are never read
[INFO] [stdout]   --> src/ship.rs:29:9
[INFO] [stdout]    |
[INFO] [stdout] 25 | pub struct Ship {
[INFO] [stdout]    |            ---- fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 29 |     pub speed: u8,
[INFO] [stdout]    |         ^^^^^
[INFO] [stdout] 30 |
[INFO] [stdout] 31 |     spec: ShipSpec,
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `set_energy_allocation` and `rotate_to` are never used
[INFO] [stdout]    --> src/ship.rs:97:12
[INFO] [stdout]     |
[INFO] [stdout]  39 | impl Ship {
[INFO] [stdout]     | --------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout]  97 |     pub fn set_energy_allocation(&mut self, e: EnergyAllocation) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 102 |     pub fn rotate_to(&mut self, new_facing: Facing) {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `defenses`, `power`, and `ship` are never read
[INFO] [stdout]   --> src/ship_spec.rs:11:9
[INFO] [stdout]    |
[INFO] [stdout]  9 | pub struct ShipSpec {
[INFO] [stdout]    |            -------- fields in this struct
[INFO] [stdout] 10 |     pub fx: Fx,
[INFO] [stdout] 11 |     pub defenses: Defenses,
[INFO] [stdout]    |         ^^^^^^^^
[INFO] [stdout] 12 |     pub power: Power,
[INFO] [stdout]    |         ^^^^^
[INFO] [stdout] 13 |     pub ship: Ship,
[INFO] [stdout]    |         ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple fields are never read
[INFO] [stdout]   --> src/ship_spec.rs:23:9
[INFO] [stdout]    |
[INFO] [stdout] 22 | pub struct Defenses {
[INFO] [stdout]    |            -------- fields in this struct
[INFO] [stdout] 23 |     pub shield1: u8,
[INFO] [stdout]    |         ^^^^^^^
[INFO] [stdout] 24 |     pub shield2: u8,
[INFO] [stdout]    |         ^^^^^^^
[INFO] [stdout] 25 |     pub shield3: u8,
[INFO] [stdout]    |         ^^^^^^^
[INFO] [stdout] 26 |     pub shield4: u8,
[INFO] [stdout]    |         ^^^^^^^
[INFO] [stdout] 27 |     pub shield5: u8,
[INFO] [stdout]    |         ^^^^^^^
[INFO] [stdout] 28 |     pub shield6: u8,
[INFO] [stdout]    |         ^^^^^^^
[INFO] [stdout] 29 |     pub armor: u8,
[INFO] [stdout]    |         ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `left_warp`, `center_warp`, `right_warp`, `impulse`, and `battery` are never read
[INFO] [stdout]   --> src/ship_spec.rs:34:9
[INFO] [stdout]    |
[INFO] [stdout] 33 | pub struct Power {
[INFO] [stdout]    |            ----- fields in this struct
[INFO] [stdout] 34 |     pub left_warp: u8,
[INFO] [stdout]    |         ^^^^^^^^^
[INFO] [stdout] 35 |     pub center_warp: u8,
[INFO] [stdout]    |         ^^^^^^^^^^^
[INFO] [stdout] 36 |     pub right_warp: u8,
[INFO] [stdout]    |         ^^^^^^^^^^
[INFO] [stdout] 37 |     pub impulse: u8,
[INFO] [stdout]    |         ^^^^^^^
[INFO] [stdout] 38 |     pub battery: u8,
[INFO] [stdout]    |         ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `forward_hull` and `aft_hull` are never read
[INFO] [stdout]   --> src/ship_spec.rs:43:9
[INFO] [stdout]    |
[INFO] [stdout] 42 | pub struct Ship {
[INFO] [stdout]    |            ---- fields in this struct
[INFO] [stdout] 43 |     pub forward_hull: u8,
[INFO] [stdout]    |         ^^^^^^^^^^^^
[INFO] [stdout] 44 |     pub aft_hull: u8,
[INFO] [stdout]    |         ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]  --> src/screen/energy_allocation_window.rs:9:19
[INFO] [stdout]   |
[INFO] [stdout] 9 |     pub fn new(e: &EnergyAllocation) -> EnergyAllocationWindow {
[INFO] [stdout]   |                   ^^^^^^^^^^^^^^^^^     ^^^^^^^^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]   |                   |
[INFO] [stdout]   |                   the lifetime is elided here
[INFO] [stdout]   |
[INFO] [stdout]   = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout]   = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]   |
[INFO] [stdout] 9 |     pub fn new(e: &EnergyAllocation) -> EnergyAllocationWindow<'_> {
[INFO] [stdout]   |                                                               ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: non-local `impl` definition, `impl` blocks should be written at the same level as their item
[INFO] [stdout]  --> src/ship_spec.rs:8:10
[INFO] [stdout]   |
[INFO] [stdout] 8 | #[derive(Deserialize)]
[INFO] [stdout]   |          ^----------
[INFO] [stdout]   |          |
[INFO] [stdout]   |          `Deserialize` is not local
[INFO] [stdout]   |          move the `impl` block outside of this constant `_IMPL_DESERIALIZE_FOR_ShipSpec`
[INFO] [stdout] 9 | pub struct ShipSpec {
[INFO] [stdout]   |            -------- `ShipSpec` is not local
[INFO] [stdout]   |
[INFO] [stdout]   = note: the derive macro `Deserialize` defines the non-local `impl`, and may need to be changed
[INFO] [stdout]   = note: the derive macro `Deserialize` may come from an old version of the `serde_derive` crate, try updating your dependency with `cargo update -p serde_derive`
[INFO] [stdout]   = note: an `impl` is never scoped, even when it is nested inside an item, as it may impact type checking outside of that item, which can be the case if neither the trait or the self type are at the same nesting level as the `impl`
[INFO] [stdout]   = note: items in an anonymous const item (`const _: () = { ... }`) are treated as in the same scope as the anonymous const's declaration for the purpose of this lint
[INFO] [stdout]   = note: `#[warn(non_local_definitions)]` on by default
[INFO] [stdout]   = note: this warning originates in the derive macro `Deserialize` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: non-local `impl` definition, `impl` blocks should be written at the same level as their item
[INFO] [stdout]   --> src/ship_spec.rs:16:10
[INFO] [stdout]    |
[INFO] [stdout] 16 | #[derive(Deserialize)]
[INFO] [stdout]    |          ^----------
[INFO] [stdout]    |          |
[INFO] [stdout]    |          `Deserialize` is not local
[INFO] [stdout]    |          move the `impl` block outside of this constant `_IMPL_DESERIALIZE_FOR_Fx`
[INFO] [stdout] 17 | pub struct Fx {
[INFO] [stdout]    |            -- `Fx` is not local
[INFO] [stdout]    |
[INFO] [stdout]    = note: the derive macro `Deserialize` defines the non-local `impl`, and may need to be changed
[INFO] [stdout]    = note: the derive macro `Deserialize` may come from an old version of the `serde_derive` crate, try updating your dependency with `cargo update -p serde_derive`
[INFO] [stdout]    = note: an `impl` is never scoped, even when it is nested inside an item, as it may impact type checking outside of that item, which can be the case if neither the trait or the self type are at the same nesting level as the `impl`
[INFO] [stdout]    = note: items in an anonymous const item (`const _: () = { ... }`) are treated as in the same scope as the anonymous const's declaration for the purpose of this lint
[INFO] [stdout]    = note: this warning originates in the derive macro `Deserialize` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: non-local `impl` definition, `impl` blocks should be written at the same level as their item
[INFO] [stdout]   --> src/ship_spec.rs:21:10
[INFO] [stdout]    |
[INFO] [stdout] 21 | #[derive(Deserialize)]
[INFO] [stdout]    |          ^----------
[INFO] [stdout]    |          |
[INFO] [stdout]    |          `Deserialize` is not local
[INFO] [stdout]    |          move the `impl` block outside of this constant `_IMPL_DESERIALIZE_FOR_Defenses`
[INFO] [stdout] 22 | pub struct Defenses {
[INFO] [stdout]    |            -------- `Defenses` is not local
[INFO] [stdout]    |
[INFO] [stdout]    = note: the derive macro `Deserialize` defines the non-local `impl`, and may need to be changed
[INFO] [stdout]    = note: the derive macro `Deserialize` may come from an old version of the `serde_derive` crate, try updating your dependency with `cargo update -p serde_derive`
[INFO] [stdout]    = note: an `impl` is never scoped, even when it is nested inside an item, as it may impact type checking outside of that item, which can be the case if neither the trait or the self type are at the same nesting level as the `impl`
[INFO] [stdout]    = note: items in an anonymous const item (`const _: () = { ... }`) are treated as in the same scope as the anonymous const's declaration for the purpose of this lint
[INFO] [stdout]    = note: this warning originates in the derive macro `Deserialize` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: non-local `impl` definition, `impl` blocks should be written at the same level as their item
[INFO] [stdout]   --> src/ship_spec.rs:32:10
[INFO] [stdout]    |
[INFO] [stdout] 32 | #[derive(Deserialize)]
[INFO] [stdout]    |          ^----------
[INFO] [stdout]    |          |
[INFO] [stdout]    |          `Deserialize` is not local
[INFO] [stdout]    |          move the `impl` block outside of this constant `_IMPL_DESERIALIZE_FOR_Power`
[INFO] [stdout] 33 | pub struct Power {
[INFO] [stdout]    |            ----- `Power` is not local
[INFO] [stdout]    |
[INFO] [stdout]    = note: the derive macro `Deserialize` defines the non-local `impl`, and may need to be changed
[INFO] [stdout]    = note: the derive macro `Deserialize` may come from an old version of the `serde_derive` crate, try updating your dependency with `cargo update -p serde_derive`
[INFO] [stdout]    = note: an `impl` is never scoped, even when it is nested inside an item, as it may impact type checking outside of that item, which can be the case if neither the trait or the self type are at the same nesting level as the `impl`
[INFO] [stdout]    = note: items in an anonymous const item (`const _: () = { ... }`) are treated as in the same scope as the anonymous const's declaration for the purpose of this lint
[INFO] [stdout]    = note: this warning originates in the derive macro `Deserialize` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: non-local `impl` definition, `impl` blocks should be written at the same level as their item
[INFO] [stdout]   --> src/ship_spec.rs:41:10
[INFO] [stdout]    |
[INFO] [stdout] 41 | #[derive(Deserialize)]
[INFO] [stdout]    |          ^----------
[INFO] [stdout]    |          |
[INFO] [stdout]    |          `Deserialize` is not local
[INFO] [stdout]    |          move the `impl` block outside of this constant `_IMPL_DESERIALIZE_FOR_Ship`
[INFO] [stdout] 42 | pub struct Ship {
[INFO] [stdout]    |            ---- `Ship` is not local
[INFO] [stdout]    |
[INFO] [stdout]    = note: the derive macro `Deserialize` defines the non-local `impl`, and may need to be changed
[INFO] [stdout]    = note: the derive macro `Deserialize` may come from an old version of the `serde_derive` crate, try updating your dependency with `cargo update -p serde_derive`
[INFO] [stdout]    = note: an `impl` is never scoped, even when it is nested inside an item, as it may impact type checking outside of that item, which can be the case if neither the trait or the self type are at the same nesting level as the `impl`
[INFO] [stdout]    = note: items in an anonymous const item (`const _: () = { ... }`) are treated as in the same scope as the anonymous const's declaration for the purpose of this lint
[INFO] [stdout]    = note: this warning originates in the derive macro `Deserialize` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 1m 22s
[INFO] running `Command { std: "docker" "inspect" "078ed15afe909ef270b5ed01a62216470a214a4ae502e1cc430c8fd680121f33", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "078ed15afe909ef270b5ed01a62216470a214a4ae502e1cc430c8fd680121f33", kill_on_drop: false }`
[INFO] [stdout] 078ed15afe909ef270b5ed01a62216470a214a4ae502e1cc430c8fd680121f33
